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(54) Compression for image boundaries 

(57) In a system where two types of data are to be 
compressed using hierarchical vector quantization 
(HVQ), it would be typical for there to be two compres- 
sion tables, one optimized for each type of data. A 



boundary between the two types may occur within a 
block to be compressed. In this case, a third table, opti- 
mized for a block having both types of data, is used. 



MM 
MM 




/ 



area of Table 1 
(2x2), Text 



I 

area of Table 2 
(2x2), Mixed 



area of Table 3 
(4x2), Contone 



CO 

in 

CO 

a> 

CO 

a> 



FIG. 8 



Q. 
LU 



Primed by Xerox (UK) Business Services 
2.16.7/3.6 



1 EP 0 969 656 A1 2 



Description 

[0001] When data must be transmitted or stored it is 
usually compressed first, to reduce the transmission 
time or storage requirement. This is especially true of s 
image data which can consist of four color separations 
of 8-bit pixels. 

[0002] One method of compression is "hierarchical 
vector quantization* (HVQ), where a block of data can 
be reduced to a single codeword in a number of steps. io 
This method is described in U.S. Patent Number 
5,602,589, and is incorporated by reference herein. 
This procedure can be explained most clearly by the 
use of a numerical example in connection with Fig 1a of 
that patent. Assume that a 2 by 4 pixel block, 8 bits per is 
pixel, is to be compressed to one 9-bit number. First, 
each pair of pixels is applied to a stage 1 look up table 
(LUT) containing 9-bit code words, each code word 
being associated with a two-pixel bit pattern. The table 
is set up so that if an exact match of the input pixel bits 20 
is not available, then a codeword associated with the 
closest match is output instead. The ultimate output of 
this stage 1 is four codewords, each describing the clos- 
est match to the bit pattern of the two input pixels. Since 
the exact match frequently is not possible, this compres- 25 
sion is inherently lossy to some extent. The output of the 
first stage is four 9-bit codewords. 
[0003] Assuming this amount of compression is not 
sufficient, these four codewords, each representing the 
bit pattern of a 1 by 2 pixel block are next applied to two 30 
stage 2 tables, resulting in a total of two 9-bit output 
codewords, each representing the bit pattern of a 2 by 2 
pixel block. If the compression is stilt insufficient, these 
two are applied to the stage 3 table to yield the final out- 
put word, which is associated with a 2 by 4 pixel block. 35 
It can now be seen that this method is hierarchical in 
that a plurality of stages are used, it involves vectors 
since the input pixels have a directional relationship with 
each other, and is quantized in that a number of levels 
can be implemented to achieve any degree of compres- 40 
sion. 

[0004] For decompression, each codeword is simply 
applied to a 256 K by 64 bit LUT which outputs the bit 
pattern of the entire 8-pixel block. 

[0005] In accordance with the present invention, a 45 

method for compressing blocks of pixels, each block 

containing a printing hint that identifies the type of block 

comprises using the hint to select one of at least three 

encoding means for encoding the block, and 

using the selected encoding means to encode the so 

block. 

[0006] In a printing system which uses HVQ, the data 
is supplied to the lossy compressor in blocks of pixels, 
each block being text, contone, halftone, etc. So that the 
compressor may configure itself optimally for the kind of ss 
data being received, the front end may supply to the 
compressor a mask which determines the boundaries 
between different kinds of data, and printing hints which 



specify which configuration should be used for the data 
that falls within each mask. In this system the mask 
edges must be aligned with the block edges. 
[0007] The system can be improved by a system for 
determining rf there is a boundary within a block, which 
can be referred to as a transition block. For example, if 
a boundary between a text character and a contone pic- 
ture runs through a block, then a printing hint wilt be 
sent to the compressor, and table values optimized for 
transition blocks can be selected for that block. This 
would improve system performance by allowing the 
compressor to operate with less loss. 
[0008] In one implementation, the process determines 
whether a block of pixels to be compressed is either of 
two types of image data, or contains a boundary 
between the types, so that the lossy compressor used 
to compress the block wilt be optimized for the first or 
second type of data, or for a transition between the two. 
[0009] Some examples of methods according to the 
present invention wilt now be described with reference 
to the accompanying drawings, in which :- 

Figure 1 is an HVQ encoder which has a parallel 
error channel; 

Figure 2 is the decoder for the arrangement of Fig- 
ure 1; 

Figure 3 is a one-channel arrangement for coding a 
pixel split into its most and least significant bits; 
Figure 4 is a one-channel arrangement for decod- 
ing a pixel split into its most and least significant 
bits; 

Figure 5 is a two-channel arrangement for coding a 
pixel split into its most and least significant bits; 
Figure 6 is a decoder for the coder of Figure 5; 
Figure 7 shows thee prices of rotating or mirror 
imaging an image using HVQ compression; 
Figure 8 shows a boundary between blocks of dif- 
ferent sizes; and, 

Figure 9 shows a boundary between blocks of the 
same size. 

[001 0] The basic HVQ system can be improved by 
adding an error channel as shown in Figure 1 . In the 
upper channel the grayscale byte map 16 is applied in 
the usual way to an HVQ encoder 10, the output is loss- 
lessly compressed in an LZ encoder 1 1 , and the result 
is sent to the decoder, usually in the form of 8 to 1 0-bit 
words. 

[0011] In addition, the output of the HVQ encoder is 
sent to a decoder 12 in scanline format which produces 
a version of the original byte map which may be different 
from the original because of errors possibly introduced 
by the lossy encoder. The two byte maps are then sub- 
tracted 13, pixel by pixel, to produce error terms which, 
if added to the output codeword, will produce the origi- 
nal byte map. This subtraction can also be done by 
using an exclusive OR, which is simpler and faster and 
does not require a sign bit. These error terms, each a 
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signed quantity 8-bits wide or less, can then be com- 
pressed in an LZ encoder 15 and sent to the decoder in 
parallel with the original output. The larger the error 
term, the less will be the compression ratio. In practice, 
small errors are not visually detectable. To limit the deg- 
radation of the compression ratio, the error term can be 
limited to a few most significant bits, three for example, 
in quantizer 14. Normally, the amount of error for a pixel 
will not be large enough to show up in the few MSB's, in 
which case there will be no error term at all. 



[001 2] The quantized error decoder is shown in Figure 
2. The compressed code words are LZ decoded in 
decoder 21 and HVQ decoded in decoder 22 to produce 
one term for the adder 23. The compressed quantized 
errors are LZ decoded in decoder 24 and applied as the 
other term to the adder 23, the output of which is output 
video. The adder 23 can either be an adder adding a 
sign bit and seven bits, or an exclusive OR if one was 
used to generate the error term in the encoder. 
[001 3] Figure 3 shows the arrangement when a si ngl e 
code word 31 is split into most and least significant 
parts, 32, 33, and where only the least significant bits 
are compressed. In this case bits 0 through 4 are sent 
through lossy compressor 35 while bits 5 through 7 are 
not. Both are then compressed using lossless LZ com- 
pression and output to the decoder shown in Figure 4. 
Here again, both channels are LZ decompressed 41 ,42 
while only the LSB's are HVQ decoded 43. The two 
resultant parts are then exclusive ORed 44 together to 
be applied to the decoding look up table. 
[0014] Figure 5 is a system where a single pixel is 
separated into a least significant segment and a most 
significant segment, and where a separate and different 
compression process 54-57 is used for each segment, 
the least significant bits being more compressed. The 
original pixel is separated into its most significant bits 52 
and least significant bits 53. The result is that the most 
significant bits, being the most important, are less com- 
pressed while compression for the least significant bits 
has a better compression ratio. A programmable look- 
up table could be used to split the input pixel into any 
two segments other than the 3 - 5 split shown. 
[001 5] Figure 6 is the decoder for the encoder of Fig- 
ure 5. The two compressed outputs of Figure 5 are 
applied to LZ decoders 61, 62 and HVQ 63, 64 
decoded. Then both are applied to an exclusive OR 
gate 65 to assemble the entire pixel. Of course, if the 
encoder used some other combination of encoders, the 
decoder would use the same form of decoding. That is, 
more generally, the data words in a string can be divided 
into more and less significant bits to create two parallel 
strings, and then compressed using any two methods of 
compression where the greater compression is applied 
to less significant bits. 

[0016] HVQ compression is easily adapted to image 
rotation and mirror imaging as shown in Figure 7. The 
process is shown here using the example of an original 
image that is four pixels high and sixteen pixels wide. 



and must be rotated ninety degrees clockwise and mir- 
ror imaged. 

[0017] Step 1 is the usual compression process of 
reducing the eight 8-pixel segments to eight codewords 
5 Cw1 to Cw8. Step 2 is the step of rearranging the code- 
words into the rotated and mirror imaged order. This 
hardware can be in the form of wiring where the second 
word in, for example Cw2, is connected to the third word 
out, as shown. Step 2 can have several sets of wiring, 
10 each set delivering a different rotation. Finally, decoding 
step 3 uses a look-up table to produce a pixel pattern for 
each segment that is properly oriented. Here again, 
several tables can be used to produce various orienta- 
tions. 

75 [0018] Printing hints may be incorporated into the 
original data supplied by the user in the original page 
description language to indicate to the printer how the 
data may best be printed. For example, a hint word may 
be two bits in length, and indicate one of four possibili- 
20 ties, that the following data is text, contone, graphics, 
etc. For example, if the printer is receiving data that orig- 
inated as a computer generated graphic it may use a dif- 
ferent halftone screen than it would if the original data 
was screened in from a photograph. ! 
25 [001 9] Printing hints may be added to any HVQ chan- 
nel as shown in Figure 5. Assume that for each 4 pixel 
block entering into the HVQ encoder 54 there is pro- 
duced one codeword 9 bits in length, contained in two 8- 
bit bytes, so that the first 8 bits are contained in the first 
30 byte and the last bit is contained in the second byte. 
Then the 2-bit hint is added. Now, each codeword plus 
hint is 11 bits, still contained in two bytes. The LZ 
encoder looks at a string of bytes, perhaps 256 bytes in 
length, and determines the location and size of the most 
35 recent identical pattern match. To the extent that the hint 
changes once or twice within that string, there will be a 
slightly decreased amount of compression in compari- 
son to the amount that would have resulted with no 
hints. However, to the extent that the hint does not 
40 change during that time, there is no decrease in com- 
pression at all. The result is that printing hints can be 
supplied after an HVQ compressor but before the loss- 
less compressor with very little effect on the compres- 
sion ratio. At the output side, after the code words are 
45 LZ decompressed, but before being decoded, the hints 
can be extracted for later use. 

[0020] The losses of an HVQ compressor can be fur- 
ther minimized by choosing codewords and output data 
patterns that have the best chance of matching the 
so actual input data patterns. For example, first consider 
text. If text pixels are being encoded in 4 by 2 pixel 
groups, and the four input pixels in one line are black, 
dark gray, light gray and white, and the input video was 
scanned-in text, the data most likely originally was a 
55 boundary between a black letter and a white space, so 
the output pixel pattern could be black, black, white, 
white. On the other hand, if the original input data was a 
scanned-in computer generated graphic, the four pixels 
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are more likely to be a smooth decrease in density from 
black to white. The actual determination of the encoder 
codewords and patterns in the decoder look-up table 
are determined by statistical analysis. A representative 
group of text and graphic documents are passed 
through a test program and the best values are gener- 
ated for each type. 

[0021 ] A complication arises when a boundary passes 
through an input block of pixels, in which case neither 
text nor graphic values can be used for the entire block. 
The solution is to supply a third set of codewords and 
patterns which are generated specifically for this bound- 
ary condition. In this case a set of documents containing 
both text and graphics would be analyzed to produce 
one set of patterns, which would be used when a 
boundary mixed, condition is determined to be within 
the block. 

[0022] The boundary condition is sensed by observing 
the printing hints. For example, a rectangular scanned- 
in picture is typically located on a page of text by its x,y 
coordinates. When the raster output scanner beam is 
within the coordinates, the printing hints will indicate to 
the printer which codewords, look-up table entries and 
halftone screens to use. If the hint changes from picture 
to text within the block, for example, then the encoder 
knows that a boundary exists within the block. 
[0023] In all cases the block size must be maintained. 
Figure 8 is an example of a transition between text and 
contone. Since different block sizes can be used in HVQ 
encoders for different kinds of data, the block size for 
the text is shown here as 2 by 2 pixels to allow greater 
edge detail while the block size for contone is shown as 
being 4 by 2 to allow for greater compression. 
[0024] If a boundary is within a 2 by 2 pixel block, that 
block is encoded and decoded using boundary values. 
In addition, any contone pixels to the right of the bound- 
ary such as pixel 81 are also treated as a boundary pix- 
els if necessary so that all remaining pixels to the right 
of the boundary fine will be within 4 by 2 pixel blocks. 
Similarly, in Figure 9. showing a boundary between 4 by 
2 pixel blocks of text and contone, 2 by 2 pixel boundary 
blocks are used in pairs so that all remaining blocks will 
be 4 by 2. 
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A method according to claim 1 or claim 2, wherein 
the hint identifies the block as one or another type 
of data, or as a boundary block containing both 
types of data. 

A method according to any of the preceding claims, 
wherein the encoding means comprise compres- 
sors, one optimized for a block containing a bound- 
ary. 

A method according to any of the preceding claims, 
wherein the encoding means use hierarchical vec- 
tor quantization. 
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Claims 



45 



A method for compressing blocks of pixels, each 
block containing a printing hint that identifies the 
type of block the method comprising the steps of: 

using the hint to select one of at least three 
encoding means for encoding the block, and 
using the selected encoding means to encode 
the block. 

A method according to claim 1, wherein each hint 
indicates that the data represents one of text, con- 
tone and graphics. 
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